package pers.xuyong.strive.datastruct.order.sample;

import pers.xuyong.strive.datastruct.order.AbstractOrder;
import pers.xuyong.strive.datastruct.order.Order;

/**
 * 冒泡
 *
 * @author billymac
 * @version 1.0
 * @date 17/5/19  下午7:51
 * @since JDK1.8
 */
public class BubbleOrder<E extends Number> extends AbstractOrder<E>
        implements Order<E> {


    @Override
    public void sort(E[] ts, int method) {
        valid(ts);
        for (int i = 0; i < ts.length; i++) {
            for (int j = 0; j < ts.length - i - 1; j++) {
                if (method > 0 && ts[j].doubleValue() > ts[j + 1].doubleValue() ||
                        method < 0 && ts[j].doubleValue() < ts[j + 1].doubleValue()) {
                    swap(ts, j, j + 1);
                }
            }
        }
    }
}
